Imports System.Data.SqlClient

Public Class cls_produccionentrega_

    Implements ICloneable

#Region "Variables ..."
    Private int_idproduccionentrega As Integer = 0
    Private int_idproduccion As Integer = 0
    Private int_idarticulo As Integer = 0
    Private dbl_cantidad As Double = 0
    Private int_idunidaddetalle As Integer = 0
    Private dte_fecha As DateTime = New System.DateTime(Now.Year, 1, 1)

    Private obj_articulo As cls_articulo_
    Private obj_unidaddetalle As cls_unidaddetalle_

    Private col_Items As Collections.Generic.List(Of cls_produccionentrega_) = Nothing
#End Region

#Region "Propiedades ..."
    ReadOnly Property This
        Get
            Return Me
        End Get
    End Property
    ReadOnly Property ThisDescripcion As String
        Get
            Return Me.ToString
        End Get
    End Property
    ReadOnly Property pKey
        Get
            Return idproduccionentrega
        End Get
    End Property
    Property idproduccionentrega() As Integer
        Get
            idproduccionentrega = int_idproduccionentrega
        End Get
        Set(ByVal value As Integer)
            int_idproduccionentrega = value
        End Set
    End Property
    Property idproduccion() As Integer
        Get
            idproduccion = int_idproduccion
        End Get
        Set(ByVal value As Integer)
            int_idproduccion = value
        End Set
    End Property
    Property idarticulo() As Integer
        Get
            idarticulo = int_idarticulo
        End Get
        Set(ByVal value As Integer)
            int_idarticulo = value
        End Set
    End Property
    Property cantidad() As Double
        Get
            cantidad = dbl_cantidad
        End Get
        Set(ByVal value As Double)
            dbl_cantidad = value
        End Set
    End Property
    Property idunidaddetalle() As Integer
        Get
            idunidaddetalle = int_idunidaddetalle
        End Get
        Set(ByVal value As Integer)
            int_idunidaddetalle = value
        End Set
    End Property
    Property fecha() As DateTime
        Get
            fecha = dte_fecha
        End Get
        Set(ByVal value As DateTime)
            dte_fecha = value
        End Set
    End Property
    Property articulo() As cls_articulo_
        Get
            If IsNothing(obj_articulo) Then
                obj_articulo = New cls_articulo_
                If Not obj_articulo.Buscar(idarticulo) Then
                    obj_articulo = Nothing
                End If
            End If
            articulo = obj_articulo
        End Get
        Set(ByVal value As cls_articulo_)
            obj_articulo = value
        End Set
    End Property
    Property unidaddetalle() As cls_unidaddetalle_
        Get
            If IsNothing(obj_unidaddetalle) Then
                obj_unidaddetalle = New cls_unidaddetalle_
                If Not obj_unidaddetalle.Buscar(idunidaddetalle) Then
                    obj_unidaddetalle = Nothing
                End If
            End If
            unidaddetalle = obj_unidaddetalle
        End Get
        Set(ByVal value As cls_unidaddetalle_)
            obj_unidaddetalle = value
        End Set
    End Property
    Property Items() As Collections.Generic.List(Of cls_produccionentrega_)
        Get
            Items = col_Items
        End Get
        Set(ByVal value As Collections.Generic.List(Of cls_produccionentrega_))
            col_Items = value
        End Set
    End Property
#End Region

    Private Sub CargarColeccion(ByVal obj_Reader As SqlDataReader)
        col_Items = New Collections.Generic.List(Of cls_produccionentrega_)
        While obj_Reader.Read()
            Dim Elemento As New cls_produccionentrega_
            Elemento.int_idproduccionentrega = (obj_Reader.GetValue(obj_Reader.GetOrdinal("idproduccionentrega")))

            If IsDBNull(obj_Reader.GetValue(obj_Reader.GetOrdinal("idproduccion"))) = False Then
                Elemento.int_idproduccion = (obj_Reader.GetValue(obj_Reader.GetOrdinal("idproduccion")))
            End If
            If IsDBNull(obj_Reader.GetValue(obj_Reader.GetOrdinal("idarticulo"))) = False Then
                Elemento.int_idarticulo = (obj_Reader.GetValue(obj_Reader.GetOrdinal("idarticulo")))
            End If
            If IsDBNull(obj_Reader.GetValue(obj_Reader.GetOrdinal("cantidad"))) = False Then
                Elemento.dbl_cantidad = (obj_Reader.GetValue(obj_Reader.GetOrdinal("cantidad")))
            End If
            If IsDBNull(obj_Reader.GetValue(obj_Reader.GetOrdinal("idunidaddetalle"))) = False Then
                Elemento.int_idunidaddetalle = (obj_Reader.GetValue(obj_Reader.GetOrdinal("idunidaddetalle")))
            End If
            If IsDBNull(obj_Reader.GetValue(obj_Reader.GetOrdinal("fecha"))) = False Then
                Elemento.dte_fecha = (obj_Reader.GetValue(obj_Reader.GetOrdinal("fecha")))
            End If
            col_Items.Add(Elemento)
        End While
    End Sub

    Private Sub CargarVariables(ByVal obj_Reader As SqlDataReader)
        obj_Reader.Read()
        int_idproduccionentrega = (obj_Reader.GetValue(obj_Reader.GetOrdinal("idproduccionentrega")))

        If IsDBNull(obj_Reader.GetValue(obj_Reader.GetOrdinal("idproduccion"))) = False Then
            int_idproduccion = (obj_Reader.GetValue(obj_Reader.GetOrdinal("idproduccion")))
        End If
        If IsDBNull(obj_Reader.GetValue(obj_Reader.GetOrdinal("idarticulo"))) = False Then
            int_idarticulo = (obj_Reader.GetValue(obj_Reader.GetOrdinal("idarticulo")))
        End If
        If IsDBNull(obj_Reader.GetValue(obj_Reader.GetOrdinal("cantidad"))) = False Then
            dbl_cantidad = (obj_Reader.GetValue(obj_Reader.GetOrdinal("cantidad")))
        End If
        If IsDBNull(obj_Reader.GetValue(obj_Reader.GetOrdinal("idunidaddetalle"))) = False Then
            int_idunidaddetalle = (obj_Reader.GetValue(obj_Reader.GetOrdinal("idunidaddetalle")))
        End If
        If IsDBNull(obj_Reader.GetValue(obj_Reader.GetOrdinal("fecha"))) = False Then
            dte_fecha = (obj_Reader.GetValue(obj_Reader.GetOrdinal("fecha")))
        End If
    End Sub

    Public Function Nuevo(Optional ByVal ObtenerID As Boolean = False) As Boolean
        Nuevo = False
        Dim obj_Conexion As New cls_Conexion
        Try
            obj_Conexion.Conectar()
            With obj_Conexion.obj_SqlCommand
                .CommandType = CommandType.StoredProcedure
                .Connection = obj_Conexion.obj_SqlConnection
                .CommandText = "produccionentrega__Nuevo"
                .Parameters.Add("@idproduccion", SqlDbType.Int).Value = int_idproduccion
                .Parameters.Add("@idarticulo", SqlDbType.Int).Value = int_idarticulo
                .Parameters.Add("@cantidad", SqlDbType.Decimal).Value = dbl_cantidad
                .Parameters.Add("@idunidaddetalle", SqlDbType.Int).Value = int_idunidaddetalle
                .Parameters.Add("@fecha", SqlDbType.DateTime).Value = dte_fecha
                .ExecuteNonQuery()
            End With
            Nuevo = True
            If ObtenerID Then
                CargarUltimo()
            End If
        Catch ex As SqlClient.SqlException
            Throw New Exception("Error al Crear el registro de produccionentrega_." & Chr(13) & _
           "Por favor informe del siguiente detalle técnico:" & Chr(13) & _
           "Nro de error: " & ex.ErrorCode & "." & Chr(13) & _
           "Descripción: " & ex.Message)
        Finally
            obj_Conexion.Desconectar()
            obj_Conexion = Nothing
        End Try
    End Function

    Public Sub Modificar()
        Dim obj_Conexion As New cls_Conexion
        Try
            obj_Conexion.Conectar()
            With obj_Conexion.obj_SqlCommand
                .CommandType = CommandType.StoredProcedure
                .Connection = obj_Conexion.obj_SqlConnection
                .CommandText = "produccionentrega__Modificar"
                .Parameters.Add("@idproduccionentrega", SqlDbType.Int).Value = int_idproduccionentrega
                .Parameters.Add("@idproduccion", SqlDbType.Int).Value = int_idproduccion
                .Parameters.Add("@idarticulo", SqlDbType.Int).Value = int_idarticulo
                .Parameters.Add("@cantidad", SqlDbType.Decimal).Value = dbl_cantidad
                .Parameters.Add("@idunidaddetalle", SqlDbType.Int).Value = int_idunidaddetalle
                .Parameters.Add("@fecha", SqlDbType.DateTime).Value = dte_fecha
                .ExecuteNonQuery()
            End With
        Catch ex As SqlClient.SqlException
            Throw New Exception("Error al Modificar el registro de produccionentrega_." & Chr(13) & _
           "Por favor informe del siguiente detalle técnico:" & Chr(13) & _
           "Nro de error: " & ex.ErrorCode & "." & Chr(13) & _
           "Descripción: " & ex.Message)
        Finally
            obj_Conexion.Desconectar()
            obj_Conexion = Nothing
        End Try
    End Sub

    Public Sub Eliminar(ByVal idproduccionentrega As Integer)
        Dim obj_Conexion As New cls_Conexion
        Try
            obj_Conexion.Conectar()
            With obj_Conexion.obj_SqlCommand
                .CommandType = CommandType.StoredProcedure
                .Connection = obj_Conexion.obj_SqlConnection
                .CommandText = "produccionentrega__Eliminar"
                .Parameters.Add("@idproduccionentrega", SqlDbType.Int).Value = idproduccionentrega
                .ExecuteNonQuery()
            End With
        Catch ex As SqlClient.SqlException
            Throw New Exception("Error al Eliminar el registro de produccionentrega_." & Chr(13) & _
           "Por favor informe del siguiente detalle técnico:" & Chr(13) & _
           "Nro de error: " & ex.ErrorCode & "." & Chr(13) & _
           "Descripción: " & ex.Message)
        Finally
            obj_Conexion.Desconectar()
            obj_Conexion = Nothing
        End Try
    End Sub

    Public Function Buscar(ByVal idproduccionentrega As Integer) As Boolean
        Dim obj_Conexion As New cls_Conexion
        Dim obj_Reader As SqlDataReader
        Try
            Buscar = False
            obj_Conexion.Conectar()
            With obj_Conexion.obj_SqlCommand
                .CommandType = CommandType.StoredProcedure
                .Connection = obj_Conexion.obj_SqlConnection
                .CommandText = "produccionentrega__Buscar"
                .Parameters.Add("@idproduccionentrega", SqlDbType.Int).Value = idproduccionentrega
            End With
            obj_Reader = obj_Conexion.obj_SqlCommand.ExecuteReader
            If obj_Reader.HasRows Then
                CargarVariables(obj_Reader)
                Buscar = True
            End If
        Catch ex As SqlClient.SqlException
            Throw New Exception("Error al Buscar el registro de produccionentrega_." & Chr(13) & _
           "Por favor informe del siguiente detalle técnico:" & Chr(13) & _
           "Nro de error: " & ex.ErrorCode & "." & Chr(13) & _
           "Descripción: " & ex.Message)
        Finally
            obj_Conexion.Desconectar()
            obj_Conexion = Nothing
            obj_Reader = Nothing
        End Try
    End Function

    Public Sub CargarUltimo()
        Dim obj_Conexion As New cls_Conexion
        Dim obj_Reader As SqlDataReader
        Try
            obj_Conexion.Conectar()
            With obj_Conexion.obj_SqlCommand
                .CommandType = CommandType.StoredProcedure
                .Connection = obj_Conexion.obj_SqlConnection
                .CommandText = "produccionentrega__CargarUltimo"
            End With
            obj_Reader = obj_Conexion.obj_SqlCommand.ExecuteReader
            If obj_Reader.HasRows Then
                CargarVariables(obj_Reader)
            End If
        Catch ex As SqlClient.SqlException
            Throw New Exception("Error al CargarUltimo registro de produccionentrega_." & Chr(13) & _
           "Por favor informe del siguiente detalle técnico:" & Chr(13) & _
           "Nro de error: " & ex.ErrorCode & "." & Chr(13) & _
           "Descripción: " & ex.Message)
        Finally
            obj_Conexion.Desconectar()
            obj_Conexion = Nothing
            obj_Reader = Nothing
        End Try
    End Sub

    Public Function CargarTodos() As Boolean
        Dim obj_Conexion As New cls_Conexion
        Dim obj_Reader As SqlDataReader
        Try
            CargarTodos = False
            obj_Conexion.Conectar()
            With obj_Conexion.obj_SqlCommand
                .CommandType = CommandType.StoredProcedure
                .Connection = obj_Conexion.obj_SqlConnection
                .CommandText = "produccionentrega__CargarTodos"
            End With
            obj_Reader = obj_Conexion.obj_SqlCommand.ExecuteReader
            If obj_Reader.HasRows Then
                CargarColeccion(obj_Reader)
                CargarTodos = True
            End If
        Catch ex As SqlClient.SqlException
            Throw New Exception("Error al CargarTodos los registros de produccionentrega_." & Chr(13) & _
           "Por favor informe del siguiente detalle técnico:" & Chr(13) & _
           "Nro de error: " & ex.ErrorCode & "." & Chr(13) & _
           "Descripción: " & ex.Message)
        Finally
            obj_Conexion.Desconectar()
            obj_Conexion = Nothing
            obj_Reader = Nothing
        End Try
    End Function

    Public Function CargarXidproduccion(ByVal prm_idproduccion As Integer) As Boolean
        Dim obj_Conexion As New cls_Conexion
        Dim obj_Reader As SqlDataReader
        Try
            CargarXidproduccion = False
            obj_Conexion.Conectar()
            With obj_Conexion.obj_SqlCommand
                .CommandType = CommandType.StoredProcedure
                .Connection = obj_Conexion.obj_SqlConnection
                .Parameters.Add("@idproduccion", SqlDbType.Int).Value = prm_idproduccion
                .CommandText = "produccionentrega__CargarXidproduccion"
            End With
            obj_Reader = obj_Conexion.obj_SqlCommand.ExecuteReader
            If obj_Reader.HasRows Then
                CargarColeccion(obj_Reader)
                CargarXidproduccion = True
            End If
        Catch ex As SqlClient.SqlException
            Throw New Exception("Error al CargarTodos los registros de produccionentrega_." & Chr(13) & _
           "Por favor informe del siguiente detalle técnico:" & Chr(13) & _
           "Nro de error: " & ex.ErrorCode & "." & Chr(13) & _
           "Descripción: " & ex.Message)
        Finally
            obj_Conexion.Desconectar()
            obj_Conexion = Nothing
            obj_Reader = Nothing
        End Try
    End Function

    Public Function Clone() As Object Implements System.ICloneable.Clone
        Dim obj_produccionentrega_Clon As New cls_produccionentrega_
        obj_produccionentrega_Clon.int_idproduccionentrega = Me.int_idproduccionentrega
        obj_produccionentrega_Clon.int_idproduccion = Me.int_idproduccion
        obj_produccionentrega_Clon.int_idarticulo = Me.int_idarticulo
        obj_produccionentrega_Clon.dbl_cantidad = Me.dbl_cantidad
        obj_produccionentrega_Clon.int_idunidaddetalle = Me.int_idunidaddetalle
        obj_produccionentrega_Clon.dte_fecha = Me.dte_fecha
        obj_produccionentrega_Clon.col_Items = Me.col_Items
        Return obj_produccionentrega_Clon
    End Function

End Class
